<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="jquery.min.js"></script>
</head>

<body>
    <script>
        // $.extend([deep],target,object1,[objectN])
        // deep:如果设为true为深拷贝，默认为浅拷贝
        // target:要拷贝的目标对象
        // object1:待拷贝到第一个对象的对象
        // objectN:待拷贝到第N个对象的对象
        // 浅拷贝是把被拷贝对象复杂数据类型中的地址拷贝给目标对象，修改目标对象会影响被拷贝对象


        // 对象拷贝 想要被某个对象拷贝
        $(function() {
            let targetObj = {};
            obj = {
                id: 1,
                name: "andy",
                msg: {
                    sex: 男
                }
            };
            $.extend(targetObj, obj); //拷贝
            console.log(targetObj);
            // 会覆盖原来的数据

            // 1.浅拷贝 把原来对象的复杂数据类型地址拷贝给目标对象
            targetObj.msg.age = 20;
            console.log(targetObj);
            console.log(obj);


            // 2.深拷贝 把里面的数据完全复制一份给目标对象，如果里面有不冲突的属性，会合并到一起
            $.extend(true, targetObj, obj);
            targetObj.msg.age = 30;
            console.log(targetObj);
            console.log(obj);
        })
    </script>

</body>

</html>